<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;

class CreatePledgeOthers extends Migration
{
    /**
     * Run the migrations.
     */
    public function up(): void
    {
        Schema::create('pledge_others', function (Blueprint $table) {
            $table->id()->from(config('migration.from'));

            $table->string('name')->nullable()->comment('Наименование');
            $table->text('characteristics')->nullable()->comment('Качественные и количественные характеристики');
            $table->text('address')->nullable()->comment('Адрес');

            $table->jsonb('object_documents')->default(json_encode([]))->comment('Документы на объект');
            $table->index('object_documents', null, 'gin');

            $table->char('serial_number')->nullable()->comment('Условный или идентификационный/серийный номер');
            $table->date('date')->nullable()->comment('Дата приобретения права собственности на объект');

            $table->text('other_information')->nullable()->comment('Иные сведения');

            $table->jsonb('documents')->default(json_encode([]))->comment('Иные документы');
            $table->index('documents', null, 'gin');

            $table->jsonb('images')->default(json_encode([]))->comment('Фото залога');
            $table->index('images', null, 'gin');
        });
    }

    /**
     * Reverse the migrations.
     */
    public function down(): void
    {
        Schema::dropIfExists('pledge_others');
    }
}
